<template>
  <view class="viewport">
    <view class="logo">
      <image
        src="https://static.botue.com/erabbit/static/images/logo_icon.png"
      ></image>
    </view>
    <view class="login">
      <button
        class="button phone"
        open-type="getPhoneNumber"
        @getphonenumber="handleGetPhoneNumber"
      >
        <text class="icon icon-phone"></text>
        手机号快捷登录
      </button>
      <view class="extra">
        <view class="caption">
          <text>其它登录方式</text>
        </view>
        <view class="options">
          <button @click="handleNextVersion">
            <text class="icon icon-weixin">微信</text>
          </button>
          <button @click="handleNextVersion">
            <text class="icon icon-phone">手机</text>
          </button>
          <button @click="handleNextVersion">
            <text class="icon icon-mail">邮箱</text>
          </button>
        </view>
      </view>
      <view class="tips"
        >登录/注册即视为你同意《服务条款》和《小兔鲜儿隐私协议》</view
      >
      <button class="button phone" @click="handleTestLogin">
        <text class="icon icon-phone"></text>
        手机号快捷登录-测试
      </button>
    </view>
  </view>
</template>

<script>
/* 
1 在登录页面 开始加载的时候 onLoad 调用小程序的 api wx.login 获取 code 
2 点击按钮的时候 获取手机号码加密信息 
  1 设置 button 的open-type 类型  getPhoneNumber 必须要大小写 敏感 看文档！！！
  2 绑定 获取手机号码事件  @getphonenumber
  3 再在事件对应回调中 获取 加密过的手机号码信息
   
3 把数据都发送给后端 来完成 登录 
4 登录成功
      1 把个人信息数据（包含token） 存到 vuex中 
      2 返回上一页即可 
*/

import { postLoginWxminSimple } from "@/http/profile";

// import { mapActions } from "vuex";
import { mapActions, mapMutations } from "vuex";
export default {
  async onLoad() {
    // uni.login 是 uni-api
    // 1 支持promise 所以我们可使用 await
    // 2 如果 它 存在 返回值，该返回值格式 数组
    //    [错误信息,返回值]
    // code 是微信小程序提供 的5分钟 有效期 临时凭据 作用：为了向我们的后端 获取token
    const [err, { code }] = await uni.login();
    this.code = code; // 设置为全局变量
  },
  methods: {
    ...mapActions("user", ["fetchProfile"]),
    ...mapMutations("user", ["setProfile"]),
    // 获取手机号码的事件回调函数  老师用的
    async handleGetPhoneNumber(event) {
      // 加密的手机号码数据
      const { encryptedData, iv } = event.detail;

      // 调用后端的登录请求  获取 个人信息 以及token
      // const result = await postLoginWxmin({
      //   encryptedData,
      //   iv,
      //   code: this.code,
      // });
      // console.log(result);

      // 异步action调用
      const res = await this.fetchProfile({
        encryptedData,
        iv,
        code: this.code,
      });
      console.log(222, res);
      // 弹出提示框
      uni.showToast({ title: "登录成功" });
      // 等待1.5s之后 返回上一页
      setTimeout(() => {
        // 调用 路由相关的api即可
        uni.navigateBack(); // 返回上一页
      }, 1500);
      // console.log(result);
    },

    // 模拟手机号码登录 同学们用这
    // async handleTestLogin() {
    //   const result = await postLoginWxminSimple(13022006386);
    //   const res = await this.fetchProfile({
    //     encryptedData,
    //     iv,
    //     code: this.code,
    //   });
    //   // 弹出提示框
    //   uni.showToast({ title: "登录成功" });
    //   // 等待1.5s之后 返回上一页
    //   setTimeout(() => {
    //     // 调用 路由相关的api即可
    //     uni.navigateBack(); // 返回上一页
    //   }, 1500);
    //   // console.log(result);
    //   // console.log(222, res);
    //   // console.log(111, result);
    // },
    async handleTestLogin() {
      this.$store.dispatch("user/fetchProfile", "13022006386");
      // this.setProfile(result.result); // 把登录后的信息 存到 vuex中
      this.$store.dispatch("user/fetchMemberProfile");

      // 弹出提示框
      uni.showToast({ title: "登录成功" });
      // 等待1.5s之后 返回上一页

      setTimeout(() => {
        // 调用 路由相关的api即可
        uni.navigateBack(); // 返回上一页
      }, 1500);
    },
  },
};
</script>

<style lang="scss">
page {
  height: 100%;
}
.viewport {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20rpx 40rpx;
}
.logo {
  flex: 1;
  text-align: center;
  image {
    width: 220rpx;
    height: 220rpx;
    margin-top: 100rpx;
  }
}
.login {
  display: flex;
  flex-direction: column;
  height: 600rpx;
  padding: 40rpx 20rpx 20rpx;
  .button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    color: #fff;
    .icon {
      font-size: 40rpx;
      margin-right: 6rpx;
    }
  }
  .phone {
    background-color: #28bb9c;
  }
  .wechat {
    background-color: #06c05f;
  }
  .extra {
    flex: 1;
    padding: 70rpx 70rpx 0;
    .caption {
      width: 440rpx;
      line-height: 1;
      border-top: 1rpx solid #ddd;
      font-size: 26rpx;
      color: #999;
      position: relative;
    }
    .options {
      display: flex;
      justify-content: center;
      margin-top: 70rpx;
    }
    .icon {
      text-align: center;
      font-size: 28rpx;
      color: #444;
      &::before {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 80rpx;
        height: 80rpx;
        margin-bottom: 6rpx;
        font-size: 40rpx;
        border: 1rpx solid #444;
        border-radius: 50%;
      }
    }
    .icon-weixin {
      &::before {
        border-color: #06c05f;
        color: #06c05f;
      }
    }
  }
  .caption {
    text {
      transform: translate(-40%);
      background-color: #fff;
      position: absolute;
      top: -12rpx;
      left: 50%;
    }
  }
  .options {
    button {
      line-height: 1;
      padding: 0;
      margin: 0 40rpx;
      background-color: transparent;
    }
  }
  .tips {
    position: absolute;
    bottom: 80rpx;
    left: 20rpx;
    right: 20rpx;
    font-size: 22rpx;
    color: #999;
    text-align: center;
  }
}
</style>